/*
 * @Description: 
 * @Version: 2.0
 * @Autor: ycw
 * @Date: 2022-01-14 17:20:58
 * @LastEditors: ycw
 * @LastEditTime: 2022-01-28 14:52:20
 */
 /**
 * v-hasPermi 操作权限处理
 * Copyright (c) 2019 ruoyi
 */
 
import {useStore} from '@/store'
import { Directive } from 'vue'
const store=useStore();
export const hasPermi: Directive = {
  mounted(el, binding, vnode) {
    const { value } = binding
    const all_permission = "*:*:*";
    const permissions = store.state && store.state.user && store.state.user.premission
    if (value && value instanceof Array && value.length > 0) {
      const permissionFlag = value
      const hasPermissions = permissions.some(permission => {
        return all_permission === permission || permissionFlag.includes(permission)
      })

      if (!hasPermissions) {
        el.parentNode && el.parentNode.removeChild(el)
      }
    } else {
      throw new Error(`请设置操作权限标签值`)
    }
  }
}
